python - 如何在python中打开一个URL
全部标签 我的网站是here.它曾经是一个Django驱动的博客。但是我不再更新它所以我只是想把它变成一个静态的HTML站点。我得到了它并使用RubyRack将它移到了Heroku。但是每个URL都解析为主页。这是因为我的config.ru文件:useRack::Static,:urls=>["/media/images","/media/js","/media/css"],:root=>"public"runlambda{|env|[200,{'Content-Type'=>'text/html','Cache-Control'=>'public,max-age=86400'},File.op
在我的测试中,我使用一些参数初始化了一个名为Package的新类。在这个类的初始化中,我打开了一个文件,该文件在我的远程机器上可用,但在本地通常不存在。我想知道如何在我的测试中stub该方法。我正在使用rspec和mocha。我试过类似的东西:File.stubs(:open).with(:file).returns(File.open("#{package_root}/test_files/test.yml"))在我的测试中初始化Package之前,我有这一行。我遇到了这个错误:unexpectedinvocation:File.open('package/test_files/te
我正在使用FacebookAPI和RubyonRails,我正在尝试解析返回的JSON。我遇到的问题是Facebookbase64URL对其数据进行编码。Ruby没有内置的base64URL解码。关于base64编码和base64URL编码的区别,seewikipedia.我如何使用Ruby/Rails对此进行解码?编辑:因为有些人阅读有困难——base64URL与base64不同 最佳答案 Dmitry的回答是正确的。它说明了在字符串解码之前必须出现的“=”符号填充。我一直收到格式错误的JSON,最后发现这是由于填充造成的。Rea
我想从任何URL中提取其路径。例如:网址:https://stackoverflow.com/questions/ask路径:questions/ask应该不难:url[/(?:\w{2,}\/).+/]但我认为我使用了错误的模式来“忽略这个”('?:'-不起作用)。什么是正确的方法? 最佳答案 我建议您不要使用正则表达式来执行此操作,而是使用内置的URI库:require'uri'uri=URI::parse('http://stackoverflow.com/questions/ask')putsuri.path#results
我可以打开.doc文件并使用Ruby获取该文件的内容吗? 最佳答案 如果你只需要纯文本内容,你可能想看看Yomu.它是一个gem,充当ApacheTIKA的包装器,它支持多种文档格式,包括以下内容:MicrosoftOfficeOLE2和OfficeOpenXML格式(.doc、.docx、.xls、.xlsx、.ppt、.pptx)OpenOffice.orgOpenDocument格式(.odt、.ods、.odp)AppleiWorks格式富文本格式(.rtf)可移植文档格式(.pdf)
假设我有一个这样的类定义:classFoodefinit(val)@val=valenddefself.bar:barenddefval@valendend规范如下:describeFooit{shouldrespond_to(:val)}it{shouldrespond_to(:bar)}end第二个it断言失败。从RSpec的文档中我不清楚respond_to应该在类方法上失败。 最佳答案 现在建议我们使用expect,像这样:describeFoodoit'shouldrespondto:bar'doexpect(Foo).t
假设我有一个字符串:“hEY”我想把它转换成“嘿”string.gsub!(/([a-z])([A-Z]+)/,'\1'.upcase)这是我的想法,但是当我在gsub方法中使用它时,upcase方法似乎什么都不做。这是为什么?编辑:我想出了这个方法:string.gsub!(/([a-z])([A-Z]+)/){|str|str.downcase!.capitalize!}有没有办法在正则表达式中做到这一点?我不太明白'\1''\2'的意思。那是反向引用吗?这是如何工作的 最佳答案 @sawa有简单的答案,你已经用另一种机制编辑了
在下面的代码中,我们必须使用?字符加入url.path和url.query吗?有更优雅的方法吗?我必须使用net/http,因为在某些情况下我也想在用户代理的header中放置一个字符串。require'net/http'url_string='http://www.time.gov/timezone.cgi?Pacific/d/-8'url=URI.parse(url_string)response=Net::HTTP.start(url.host,url.port)do|http|http.get(url.path+'?'+url.query)endputsresponse.bod
在Ruby中,我们可以访问带有负数的数组,如array[-1]以获取数组中的最后一个对象。我如何使用XPath执行此操作?我不能这样做:result=node.xpath('.//ROOT/TAG[-1]/KEY_NAME')我在StackOverflow上找到了一个解决方案,但那是一个仅更改上限以获取元素的查询。这可能会返回最后一项或最后一项和上一项。如果我想在Ruby中只获取前一个元素,如array[-2]怎么办? 最佳答案 您可以在谓词中使用last()访问XPath中的最后一个元素。node.xpath('.//ROOT/T
我有一个Ruby/Rails应用程序,它有两个或三个主要“部分”。当用户访问该部分时,我希望显示一些子导航。所有三个部分都使用相同的布局,因此我无法将导航“硬编码”到布局中。我可以想到几种不同的方法来做到这一点。我想为了帮助人们投票,我会把它们作为答案。还有其他想法吗?或者你投票给什么? 最佳答案 假设每个部分都有自己的Controller,您可以使用partials轻松地做到这一点。假设您有三个部分,分别称为Posts、Users和Admin,每个部分都有自己的Controller:PostsController、UsersCon